<template>
  <div class="app">
    <router-view />
  </div>
</template>

<script>
export default {
  name: 'App',
  mounted() {
    // 应用启动时执行
    console.log('App Mounted')
    
    // 检查网络状态
    this.checkNetworkStatus()
    
    // 初始化应用数据
    this.initAppData()
  },
  methods: {
    checkNetworkStatus() {
      // 检查网络状态 - 使用标准浏览器API代替uni
      if (navigator.onLine) {
        console.log('网络连接正常')
      } else {
        console.log('当前无网络连接')
        alert('当前无网络连接')
      }
      
      // 监听网络状态变化
      window.addEventListener('online', () => {
        console.log('网络已连接')
      })
      
      window.addEventListener('offline', () => {
        console.log('网络已断开')
        alert('网络连接已断开')
      })
    },
    
    initAppData() {
      // 初始化应用数据
      // 可以在这里加载用户配置、检查更新等
      console.log('初始化应用数据')
    }
  }
}
</script>

<style>
/* 全局样式 */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  height: 100%;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-size: 14px;
  color: #333;
  background-color: #f5f5f5;
}

.app {
  width: 100%;
  min-height: 100vh;
}

/* 全局主题颜色 */
:root {
  --primary-color: #07c160;
  --primary-dark: #06ad56;
  --primary-light: #f0f9f4;
  --text-color: #333333;
  --text-secondary: #666666;
  --text-light: #999999;
  --border-color: #eeeeee;
  --background-color: #f5f5f5;
  --white: #ffffff;
  --red: #e64340;
  --orange: #ff9500;
  --blue: #1989fa;
  --green: #07c160;
  --gray: #f5f5f5;
}

/* 全局按钮样式 */
button {
  border: none;
  outline: none;
  cursor: pointer;
  font-size: 14px;
  transition: all 0.3s ease;
}

/* 全局输入框样式 */
input, textarea {
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 8px 12px;
  font-size: 14px;
  outline: none;
  transition: border-color 0.3s ease;
}

input:focus, textarea:focus {
  border-color: var(--primary-color);
}

/* 全局链接样式 */
a {
  color: var(--primary-color);
  text-decoration: none;
}

a:hover {
  color: var(--primary-dark);
}

/* 全局阴影样式 */
.shadow {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.shadow-lg {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

/* 全局圆角样式 */
.rounded {
  border-radius: 6px;
}

.rounded-lg {
  border-radius: 10px;
}

.rounded-full {
  border-radius: 50%;
}

/* 全局布局样式 */
.flex {
  display: flex;
}

.flex-column {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.justify-around {
  justify-content: space-around;
}

.align-center {
  align-items: center;
}

.align-start {
  align-items: flex-start;
}

.align-end {
  align-items: flex-end;
}

/* 文本样式 */
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.text-primary {
  color: var(--primary-color);
}

.text-secondary {
  color: var(--text-secondary);
}

.text-light {
  color: var(--text-light);
}

.text-red {
  color: var(--red);
}

.text-sm {
  font-size: 12px;
}

.text-lg {
  font-size: 16px;
}

.text-xl {
  font-size: 18px;
}

.font-bold {
  font-weight: bold;
}

/* 间距样式 */
.m-1 { margin: 4px; }
.m-2 { margin: 8px; }
.m-3 { margin: 12px; }
.m-4 { margin: 16px; }
.m-5 { margin: 20px; }

.p-1 { padding: 4px; }
.p-2 { padding: 8px; }
.p-3 { padding: 12px; }
.p-4 { padding: 16px; }
.p-5 { padding: 20px; }

.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-5 { margin-top: 20px; }

.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-5 { margin-bottom: 20px; }

.ml-1 { margin-left: 4px; }
.ml-2 { margin-left: 8px; }
.ml-3 { margin-left: 12px; }
.ml-4 { margin-left: 16px; }
.ml-5 { margin-left: 20px; }

.mr-1 { margin-right: 4px; }
.mr-2 { margin-right: 8px; }
.mr-3 { margin-right: 12px; }
.mr-4 { margin-right: 16px; }
.mr-5 { margin-right: 20px; }

.pt-1 { padding-top: 4px; }
.pt-2 { padding-top: 8px; }
.pt-3 { padding-top: 12px; }
.pt-4 { padding-top: 16px; }
.pt-5 { padding-top: 20px; }

.pb-1 { padding-bottom: 4px; }
.pb-2 { padding-bottom: 8px; }
.pb-3 { padding-bottom: 12px; }
.pb-4 { padding-bottom: 16px; }
.pb-5 { padding-bottom: 20px; }

.pl-1 { padding-left: 4px; }
.pl-2 { padding-left: 8px; }
.pl-3 { padding-left: 12px; }
.pl-4 { padding-left: 16px; }
.pl-5 { padding-left: 20px; }

.pr-1 { padding-right: 4px; }
.pr-2 { padding-right: 8px; }
.pr-3 { padding-right: 12px; }
.pr-4 { padding-right: 16px; }
.pr-5 { padding-right: 20px; }
</style>